← Index
NYTProf Performance Profile   
For ../prof.pl
  Run on Wed Dec 14 15:57:08 2022
Reported on Wed Dec 14 16:00:35 2022

Filename(eval 355)[/Users/ether/.perlbrew/libs/36.0@std/lib/perl5/Sub/Quote.pm:3]
StatementsExecuted 133 statements in 645µs
Eval Invoked At/Users/ether/.perlbrew/libs/36.0@std/lib/perl5/Sub/Quote.pm line 3
Sibling evals1, 2, 3, 4, 5, 6, 7, 8, 9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24, 25, 26, 27, 28, 29, 30, 31, 32, 33, 34, 35, 36, 37, 38, 39, 40, 41, 42, 43, 44, 45, 46, 47, 48, 49, 50, 51, 52, 53, 54, 55, 56, 57, 58, 59, 60, 61, 62, 63, 64, 65, 66, 67, 68, 69, 70, 71, 72, 73, 74, 75, 76, 77, 78, 79, 80, 81, 82, 83, 84, 85, 86, 87, 88, 89, 90, 91, 92, 93, 94, 95, 96, 97, 98, 99, 100, 101, 102, 103, 104, 105, 106, 107, 108, 109, 110, 111, 112, 113
Subroutines
Calls P F Exclusive
Time
Inclusive
Time
Subroutine
1033118µs60.5msJSON::Schema::Modern::::_assert__vocabulary_classes JSON::Schema::Modern::_assert__vocabulary_classes
11142µs89µsJSON::Schema::Modern::::BEGIN@7.210 JSON::Schema::Modern::BEGIN@7.210
11117µs17µsMethod::Generate::Accessor::_Generated::::BEGIN@12.211Method::Generate::Accessor::_Generated::BEGIN@12.211
1119µs26µsMethod::Generate::Accessor::_Generated::::BEGIN@24.212Method::Generate::Accessor::_Generated::BEGIN@24.212
Call graph for these subroutines as a Graphviz dot language file.
Line State
ments
Time
on line
Calls Time
in subs
Code
1{
222µs my $isa_check_for__5fvocabulary_5fclasses = ${$_[1]->{"\$isa_check_for__5fvocabulary_5fclasses"}};
311µs my $_QUOTED = ${$_[1]->{"\$_QUOTED"}};
410s my $default_for__5fvocabulary_5fclasses = ${$_[1]->{"\$default_for__5fvocabulary_5fclasses"}};
510s my $_UNQUOTED = ${$_[1]->{"\$_UNQUOTED"}};
6 package JSON::Schema::Modern;
7293µs2136µs
# spent 89µs (42+47) within JSON::Schema::Modern::BEGIN@7.210 which was called: # once (42µs+47µs) by Sub::Quote::_clean_eval at line 7
no warnings 'closure';
# spent 89µs making 1 call to JSON::Schema::Modern::BEGIN@7.210 # spent 47µs making 1 call to warnings::unimport
8
# spent 60.5ms (118µs+60.4) within JSON::Schema::Modern::_assert__vocabulary_classes which was called 10 times, avg 6.05ms/call: # 8 times (9µs+0s) by JSON::Schema::Modern::_get_vocabulary_class at line 17 of (eval 352)[Sub/Quote.pm:3], avg 1µs/call # once (105µs+60.4ms) by JSON::Schema::Modern::_get_vocabulary_values at line 17 of (eval 354)[Sub/Quote.pm:3] # once (4µs+0s) by JSON::Schema::Modern::_set_vocabulary_class at line 17 of (eval 353)[Sub/Quote.pm:3]
sub _assert__vocabulary_classes {
9 ($_QUOTED,$_UNQUOTED) if 0;
10# BEGIN quote_sub PRELUDE
11package Method::Generate::Accessor::_Generated;
12
# spent 17µs within Method::Generate::Accessor::_Generated::BEGIN@12.211 which was called: # once (17µs+0s) by Sub::Quote::_clean_eval at line 17
BEGIN {
1311µs $^H = 2018;
1411µs ${^WARNING_BITS} = "UUUUUUUUUUUUUUUUUUUU";
15117µs %^H = (
16 );
17174µs117µs}
18# END quote_sub PRELUDE
191021µsdo {
20 my $val = exists $_[0]->{"_vocabulary_classes"} ?
21$_[0]->{"_vocabulary_classes"}
22104µs: do {
2313µs160.3ms my $value = $default_for__5fvocabulary_5fclasses->($_[0]);
2479409µs44180µs
# spent 26µs (9+17) within Method::Generate::Accessor::_Generated::BEGIN@24.212 which was called: # once (9µs+17µs) by Sub::Quote::_clean_eval at line 24
do { no warnings "void"; package Type::Tiny; (do { package Type::Tiny; (Ref::Util::XS::is_plain_hashref($value)) and do { my $ok = 1; for my $i (values %{$value}) { ($ok = 0, last) unless do { package Type::Tiny; (Ref::Util::XS::is_plain_arrayref($i)) and @{$i} == 2 and (defined($i->[0]) and !ref($i->[0]) and $i->[0] =~ m{\A(?:draft(?:20(?:19\-09|20\-12)|7))\z}) and ((do { package Type::Tiny; Types::Standard::_is_class_loaded(do { my $tmp = $i->[1] }) }) && (do { local $_ = $i->[1]; $_->DOES('JSON::Schema::Modern::Vocabulary') })) } }; $ok } }) or Type::Tiny::_failed_check($isa_check_for__5fvocabulary_5fclasses, "HashRef[Tuple[Enum[\"draft7\",\"draft2019-09\",\"draft2020-12\"],__ANON__]]", $value, "attribute_name","_vocabulary_classes","attribute_step","isa check","mgaca","0","varname","\$self->{\"_vocabulary_classes\"}"); $value };
# spent 38µs making 14 calls to Types::Standard::__ANON__[(eval 46)[Types/Standard.pm:48]:16], avg 3µs/call # spent 26µs making 1 call to Method::Generate::Accessor::_Generated::BEGIN@24.212 # spent 20µs making 2 calls to JSON::Schema::Modern::Vocabulary::Applicator::DOES, avg 10µs/call # spent 17µs making 1 call to warnings::unimport # spent 13µs making 2 calls to JSON::Schema::Modern::Vocabulary::FormatAnnotation::DOES, avg 6µs/call # spent 13µs making 2 calls to JSON::Schema::Modern::Vocabulary::Validation::DOES, avg 6µs/call # spent 12µs making 2 calls to JSON::Schema::Modern::Vocabulary::Core::DOES, avg 6µs/call # spent 11µs making 2 calls to JSON::Schema::Modern::Vocabulary::MetaData::DOES, avg 6µs/call # spent 9µs making 2 calls to JSON::Schema::Modern::Vocabulary::Content::DOES, avg 4µs/call # spent 8µs making 1 call to JSON::Schema::Modern::Vocabulary::FormatAssertion::DOES # spent 7µs making 1 call to JSON::Schema::Modern::Vocabulary::Unevaluated::DOES # spent 6µs making 14 calls to Type::Tiny::CORE:match, avg 429ns/call
2512µs $_[0]->{"_vocabulary_classes"} = $value
26 }
27;
28101µs exists $_[0]->{"_vocabulary_classes"}
29 or Carp::croak(q{Attempted to access '}."_vocabulary_classes".q{' but it is not set});
30101µs $val;
31}
32 }
3312µs $$_UNQUOTED = \&_assert__vocabulary_classes;
34}
35113µs1;
36
37;